<template>
  <div class="vue-box">
    <div class="c-panel">
      <!-- 参数栏 -->
      <div class="c-title">检索参数</div>
      <el-form @submit.native.prevent>
        <sa-item v-model="p.search" type="text" name="模糊搜索" />
        <sa-item v-model="p.status" type="enum" jtype="4" :jv="dims.EXEC_STATUS" name="任务状态" :def="{}"
          :clearable="true" />
        <div class="c-item">
          <el-button type="primary" icon="el-icon-search" @click="f5()">查询</el-button>
        </div>
      </el-form>
      <!-- ------------- 快捷按钮 ------------- -->
      <sa-item type="fast-btn" show="get,delete,export,reset" />
      <!-- 数据列表 -->
      <el-table ref="data-table" class="data-table" :data="dataList" border>
        <sa-td type="selection" width="45px" />
        <sa-td type="text" name="序号" prop="id" width="80px" />
        <sa-td type="text" name="任务名" prop="taskName" />
        <sa-td type="enum" name="执行器类" prop="actuatorId" :jv="dims.ACTUATORS" />
        <sa-td type="text" name="表达式" prop="cronExpression" />
        <sa-td type="text" name="任务日志" prop="logs" />
        <sa-td type="text" name="异常信息" prop="note" />
        <sa-td type="enum" name="任务状态" prop="status" :jv="dims.EXEC_STATUS" />
        <sa-td type="datetime" name="创建时间" prop="createTime" />
      </el-table>
      <!-- 分页 -->
      <div v-if="dataCount">
        <sa-item type="page" :curr.sync="p.current" :size.sync="p.size" :total="dataCount" @change="f5()" />
      </div>
    </div>
  </div>
</template>

<script>

export default {
  name: 'scheduled-logs-list',
  data() {
    return {
      // 查询参数
      p: {
        current: 1,
        size: 10,
        search: null,
        status: null,
        sortField: null
      },
      dataCount: null,
      // 数据集合
      dataList: [],
      // 缓存字典
      dims: {},
    }
  },
  created() {
    this.dims = sa.$sys.getCurd()
    this.f5();
    // 监听表单回车执行查询
    sa.onInputEnter();
  },
  methods: {
    // 刷新
    f5: function () {
      sa.ajax('/scheduled/logs/getList', this.p, function (res) {
        // 数据
        this.dataList = res.data;
        // 数据总数
        this.dataCount = res.dataCount;
        // 刷新表格高度
        sa.f5TableHeight();
      }.bind(this));
    },

    // 批量删除
    deleteByIds: function () {
      // 获取选中元素的id列表
      let selection = this.$refs['data-table'].selection;
      let ids = sa.getArrayField(selection, 'id');
      if (selection.length == 0) {
        return sa.msg('请至少选择一条数据')
      }
      // 提交删除
      sa.confirm('是否批量删除选中数据？此操作不可撤销', function () {
        sa.ajax('/scheduled/logs/deleteByIds', { ids: ids }, function (res) {
          sa.ok('删除成功');
          this.f5();
        }.bind(this))
      }.bind(this));
      // 刷新表格高度
      sa.f5TableHeight();
    },
    // 查看详情
    getInfo: function (data) {
      sa.showModel('详情', () => import('./info'), { id: data.id, dims: this.dims });
    },

    // 查看 - 根据选中的
    getBySelect: function () {
      var selection = this.$refs['data-table'].selection;
      if (selection.length === 0) {
        return sa.msg('请至少选择一条数据')
      }
      this.getInfo(selection[0]);
    },
  }
}
</script>

<style scoped>
.el-tag {
  border-radius: 2px;
  margin-left: 2px;
  background-color: transparent;
}
</style>
